package com.sg.model.componnet.po;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.sg.framework.common.annotations.LikeFlag;
import com.sg.framework.common.po.BaseEntity;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotNull;
import lombok.Data;
import java.io.Serial;
import lombok.experimental.Accessors;

import java.io.Serial;
import java.util.Date;

/**
 * 辅表，一个小版本，不需要前置判断可作废，表类型（空间独有）
 * 1、（直接关系，就是文档与内容对象直接关联；间接关系，就是文档与内容对象上级间接关联；引用关系，就是文档引用其他内容对象的文档）
 * 2、归属类型不同，一级、二级、三级属性可个性组合使用。
 * 3、间接关系的内容对象的文档，一级、二级属性有值。（间接关系本期不做）
 *
 * @author xxx
 */
@Data
@Accessors(chain = true)
@TableName("oms_unstructured_data_relationship")    //2-7-03 文档关系表
public class OmsUnstructuredDataRelationship extends BaseEntity {

    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * 文档关系ID
     */
    @TableId(value = "unstructured_data_relationship_id", type = IdType.ASSIGN_UUID)
    @NotNull(message = "unstructuredDataRelationshipId不能为空")
    private String unstructuredDataRelationshipId;

    /**
     * 归属工作周期ID
     */
    @TableField(value = "own_work_cycle_id")
    @Schema(description = "归属工作周期ID")
    private String ownWorkCycleId;

    /**
     * 冗余版权归属对象类型 ORGANIZATION:组织 DEPARTMENT:部门 PERSONAL:个人
     */
    @TableField(value = "copyright_object_type_code")
    @Schema(description = "冗余版权归属对象类型")
    private String copyrightObjectTypeCode;

    /**
     * 文档ID
     */
    @TableField(value = "unstructured_data_id")
    @NotNull(message = "文档ID不能为空")
    @Schema(description = "文档ID")
    private String unstructuredDataId;

    /**
     * 归属内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_ACHIEVEMENT:成果表 OMS_ACHIEVEMENT_TYPE:成果类型表 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表 OMS_VIRTUAL_ORG:虚拟组织表 OMS_MESSAGE:消息表 OMS_MESSAGE_LOCATION:消息位置表 OMS_MESSAGE_MEMBER:成员接收消息表 OMS_MESSAGE_MEMBER_CHANNEL_RELATION:成员通道关系表 OMS_FRAMEWORK_SPACE_MEMBER:成员表
     */
    @TableField(value = "own_table_type_code")
    @NotNull(message = "归属内容表类型编码不能为空")
    @Schema(description = "归属内容表类型编码")
    private String ownTableTypeCode;

    /**
     * 冗余版权归属对象ID
     */
    @TableField(value = "copyright_object_id")
    @Schema(description = "冗余版权归属对象ID")
    private String copyrightObjectId;

    /**
     * 来源文档关系ID
     */
    @TableField(value = "source_relationship_id")
    @Schema(description = "来源文档关系ID")
    private String sourceRelationshipId;

    /**
     * 归属内容表主键ID
     */
    @TableField(value = "own_entity_id")
    @NotNull(message = "归属内容表主键ID不能为空")
    @Schema(description = "归属内容表主键ID")
    private String ownEntityId;

    /**
     * 文件相对路径地址
     */
    @TableField(value = "file_relative_path_access")
    @NotNull(message = "文件相对路径地址不能为空")
    @Schema(description = "文件相对路径地址")
    private String fileRelativePathAccess;

    /**
     * 文档名称
     */
    @TableField(value = "unstructured_data_name")
    @Schema(description = "文档名称")
    @LikeFlag(likeType = "LIKE")
    private String unstructuredDataName;

    /**
     * 冗余是否标志性成果 TRUE:是 FALSE:否
     */
    @TableField(value = "is_symbolic_achievements")
    @Schema(description = "冗余是否标志性成果")
    private String isSymbolicAchievements;

    /**
     * 关系类型编码 DIRECT_RELATION:直接关系 INDIRECT_RELATIONSHIP:间接关系
     */
    @TableField(value = "relationship_type")
    @NotNull(message = "关系类型编码不能为空")
    @Schema(description = "关系类型编码")
    private String relationshipType;

    /**
     * 归属父内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_ACHIEVEMENT:成果表 OMS_ACHIEVEMENT_TYPE:成果类型表 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表 OMS_VIRTUAL_ORG:虚拟组织表 OMS_MESSAGE:消息表 OMS_MESSAGE_LOCATION:消息位置表 OMS_MESSAGE_MEMBER:成员接收消息表 OMS_MESSAGE_MEMBER_CHANNEL_RELATION:成员通道关系表 OMS_FRAMEWORK_SPACE_MEMBER:成员表
     */
    @TableField(value = "own_parent_content_type_code")
    @Schema(description = "归属父内容表类型编码")
    private String ownParentContentTypeCode;

    /**
     * 归属个人账号ID
     */
    @TableField(value = "user_id")
    @NotNull(message = "归属个人账号ID不能为空")
    @Schema(description = "归属个人账号ID")
    private String userId;

    /**
     * 文档后缀
     */
    @TableField(value = "postfix")
    @NotNull(message = "文档后缀不能为空")
    @Schema(description = "文档后缀")
    private String postfix;

    /**
     * 归属父内容标识
     */
    @TableField(value = "own_parent_content_code")
    @Schema(description = "归属父内容标识")
    @LikeFlag(likeType = "RIGHT_LIKE")
    private String ownParentContentCode;

    /**
     * 文档应用业务场景 BASIC_FUNCTIONS:基础功能 WORK_TASKS:工作任务 PLANNING:规划 PERFORMANCE:绩效 DESIGN_WORK:设计工作 ACHIVEMENT:成果
     */
    @TableField(value = "doc_use_scene_code")
    @Schema(description = "文档应用业务场景")
    private String docUseSceneCode;

    /**
     * 文档用途类型 REPORT_THUMBNAIL:汇报缩略图 REPORT_CONTENT:汇报内容图 REPORT_ATTACH:汇报附件 PLAN_DATA:规划资料 PLAN_DATA_CONTENT:规划资料内容图 USER_HEAD:用户头像 APP_FRAME_LOGO:应用框架logo ABOUT_US_LOGO:关于我们logo APP_BANNE:应用banner SPACE_HEAD:空间头像 SCENE_LOGO:场景logo POWER_ICON:权限图标 ROLE_ICON:角色图标 PERSON_INFO_DOCK:个人岗位信息对接 DEPT_INFO_DOCK:部门信息对接 WORK_TASK_THUMBNAIL_PIC:工作任务缩略图 WORK_TASK_ATT:工作任务附件 OFFICIAL_DOCUMENT_FILE:公文文件 OFFICIAL_DOCUMENT_ANNEX:公文附件 PROJECT_ATTACH:项目附件 PROJECT_PIC:项目附图 PROBLEM_ATTACH:问题附件 PROBLEM_PIC:问题附图 ACHIVEMENT:成果附件 ACHIVEMENT_PIC:成果附图
     */
    @TableField(value = "doc_use_type")
    @NotNull(message = "文档用途类型不能为空")
    @Schema(description = "文档用途类型")
    private String docUseType;

    /**
     * 归属父内容表主键ID
     */
    @TableField(value = "own_parent_content_id")
    @Schema(description = "归属父内容表主键ID")
    private String ownParentContentId;

    /**
     * 是否是网盘引用关系 TRUE:是 FALSE:否
     */
    @TableField(value = "is_network_reference")
    @Schema(description = "是否是网盘引用关系")
    private String isNetworkReference;

    /**
     * 主题内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_ACHIEVEMENT:成果表 OMS_ACHIEVEMENT_TYPE:成果类型表 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表 OMS_VIRTUAL_ORG:虚拟组织表 OMS_MESSAGE:消息表 OMS_MESSAGE_LOCATION:消息位置表 OMS_MESSAGE_MEMBER:成员接收消息表 OMS_MESSAGE_MEMBER_CHANNEL_RELATION:成员通道关系表 OMS_FRAMEWORK_SPACE_MEMBER:成员表
     */
    @TableField(value = "theme_content_type_code")
    @Schema(description = "主题内容表类型编码")
    private String themeContentTypeCode;

    /**
     * 冗余是否结果文档 TRUE:是 FALSE:否
     */
    @TableField(value = "is_result")
    @Schema(description = "冗余是否结果文档")
    private String isResult;

    /**
     * 主题内容ID
     */
    @TableField(value = "theme_content_id")
    @Schema(description = "主题内容ID")
    private String themeContentId;

    /**
     * 排序
     */
    @TableField(value = "order_number")
    @NotNull(message = "排序不能为空")
    @Schema(description = "排序")
    private Long orderNumber;

    /**
     * 操作人就职记录ID
     */
    @TableField(value = "operation_induction_id")
    @NotNull(message = "操作人就职记录ID不能为空")
    @Schema(description = "操作人就职记录ID")
    private String operationInductionId;

    /**
     * 创建人就职记录ID
     */
    @TableField(value = "create_induction_id")
    @NotNull(message = "创建人就职记录ID不能为空")
    @Schema(description = "创建人就职记录ID")
    private String createInductionId;

    /**
     * 操作时间
     */
    @TableField(value = "operate_time")
    @NotNull(message = "操作时间不能为空")
    @Schema(description = "操作时间")
    private Date operateTime;

    /**
     * 创建时间
     */
    @TableField(value = "create_time")
    @NotNull(message = "创建时间不能为空")
    @Schema(description = "创建时间")
    private Date createTime;

    /**
     * 是否作废 TRUE:是 FALSE:否
     */
    @TableField(value = "is_valid")
    @NotNull(message = "是否作废不能为空")
    @Schema(description = "是否作废")
    private String isValid;

    /**
     * 创建于空间ID
     */
    @TableField(value = "space_id")
    @NotNull(message = "创建于空间ID不能为空")
    @Schema(description = "创建于空间ID")
    private String spaceId;

    /**
     * 创建于联盟应用ID
     */
    @TableField(value = "app_id")
    @NotNull(message = "创建于联盟应用ID不能为空")
    @Schema(description = "创建于联盟应用ID")
    private String appId;
}
